Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
prosemirror-highlight
Advanced tools
Highlight your code blocks in ProseMirror, with any syntax highlighter you like!
import { getHighlighter } from 'shiki'
import { createHighlightPlugin } from 'prosemirror-highlight'
import { createParser } from 'prosemirror-highlight/shiki'
const highlighter = await getHighlighter({
themes: ['github-light'],
langs: ['javascript', 'typescript', 'python'],
})
const parser = createParser(highlighter)
export const shikiPlugin = createHighlightPlugin({ parser })
import { getHighlighter, type Highlighter, type BuiltinLanguage } from 'shiki'
import { createHighlightPlugin } from 'prosemirror-highlight'
import { createParser, type Parser } from 'prosemirror-highlight/shiki'
let highlighterPromise: Promise<void> | undefined
let highlighter: Highlighter | undefined
let parser: Parser | undefined
const loadedLanguages = new Set<string>()
/**
* Lazy load highlighter and highlighter languages.
*
* When the highlighter or the required language is not loaded, it returns a
* promise that resolves when the highlighter or the language is loaded.
* Otherwise, it returns an array of decorations.
*/
const lazyParser: Parser = (options) => {
if (!highlighterPromise) {
highlighterPromise = getHighlighter({
themes: ['github-light'],
langs: [],
}).then((h) => {
highlighter = h
})
return highlighterPromise
}
if (!highlighter) {
return highlighterPromise
}
const language = options.language
if (language && !loadedLanguages.has(language)) {
return highlighter.loadLanguage(language as BuiltinLanguage).then(() => {
loadedLanguages.add(language)
})
}
if (!parser) {
parser = createParser(highlighter)
}
return parser(options)
}
export const shikiLazyPlugin = createHighlightPlugin({ parser: lazyParser })
import { getHighlighter } from 'shikiji'
import { createHighlightPlugin } from 'prosemirror-highlight'
import { createParser } from 'prosemirror-highlight/shikiji'
const highlighter = await getHighlighter({
themes: ['vitesse-light'],
langs: ['javascript', 'typescript', 'python'],
})
const parser = createParser(highlighter)
export const shikijiPlugin = createHighlightPlugin({ parser })
import { getHighlighter, type Highlighter, type BuiltinLanguage } from 'shikiji'
import { createHighlightPlugin, type Parser } from 'prosemirror-highlight'
import { createParser } from 'prosemirror-highlight/shikiji'
let highlighterPromise: Promise<void> | undefined
let highlighter: Highlighter | undefined
let parser: Parser | undefined
const loadedLanguages = new Set<string>()
/**
* Lazy load highlighter and highlighter languages.
*
* When the highlighter or the required language is not loaded, it returns a
* promise that resolves when the highlighter or the language is loaded.
* Otherwise, it returns an array of decorations.
*/
const lazyParser: Parser = (options) => {
if (!highlighterPromise) {
highlighterPromise = getHighlighter({
themes: ['vitesse-light'],
langs: [],
}).then((h) => {
highlighter = h
})
return highlighterPromise
}
if (!highlighter) {
return highlighterPromise
}
const language = options.language
if (language && !loadedLanguages.has(language)) {
return highlighter.loadLanguage(language as BuiltinLanguage).then(() => {
loadedLanguages.add(language)
})
}
if (!parser) {
parser = createParser(highlighter)
}
return parser(options)
}
export const shikijiLazyPlugin = createHighlightPlugin({ parser: lazyParser })
import 'highlight.js/styles/default.css'
import { common, createLowlight } from 'lowlight'
import { createHighlightPlugin } from 'prosemirror-highlight'
import { createParser } from 'prosemirror-highlight/lowlight'
const lowlight = createLowlight(common)
const parser = createParser(lowlight)
export const lowlightPlugin = createHighlightPlugin({ parser })
import { refractor } from 'refractor'
import { createHighlightPlugin } from 'prosemirror-highlight'
import { createParser } from 'prosemirror-highlight/refractor'
const parser = createParser(refractor)
export const refractorPlugin = createHighlightPlugin({ parser })
MIT
FAQs
A ProseMirror plugin to highlight code blocks
The npm package prosemirror-highlight receives a total of 20,320 weekly downloads. As such, prosemirror-highlight popularity was classified as popular.
We found that prosemirror-highlight demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.